import axios from 'axios'
import { clearToken, getToken } from './token'
import router from '@/router'

const http = axios.create({
  baseURL: 'http://localhost/',
  timeout: 5000
})

// 添加请求拦截器
http.interceptors.request.use((config) => {
  const token = getToken()
  if (token){
    config.headers.Authorization = `Bearer ${token}`
  }
  return config
}, (error) => {
  return Promise.reject(error)
})

// 添加响应拦截器
http.interceptors.response.use((response) => {
  // 2xx 范围内的状态码都会触发该函数。
  // 对响应数据做点什么
  return response.data
}, (error) => {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  if(error.response.status === 401){
    clearToken()
    router.navigate('/login')
    // window.location.reload() 测试结果：不强制刷新是没有问题。
  }
  return Promise.reject(error)
})

export { http }